//package org.exez.modules.system.controller;
//
//import java.util.*;
//import javax.servlet.http.HttpServletRequest;
//import javax.servlet.http.HttpServletResponse;
//
//import com.alibaba.fastjson.JSONObject;
//import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
//import org.apache.shiro.SecurityUtils;
//import org.exez.common.api.vo.Result;
//import org.exez.common.system.query.QueryGenerator;
//import org.exez.common.aspect.annotation.AutoLog;
//import org.exez.common.system.vo.LoginUser;
//import org.exez.common.util.oConvertUtils;
//import org.exez.modules.system.entity.*;
//import org.exez.modules.system.service.*;
//import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
//import com.baomidou.mybatisplus.core.metadata.IPage;
//import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
//import lombok.extern.slf4j.Slf4j;
//import org.exez.common.system.base.controller.JeecgController;
//
//import org.springframework.beans.factory.annotation.Autowired;
//import org.springframework.web.bind.annotation.*;
//import org.springframework.web.servlet.ModelAndView;
//import io.swagger.annotations.Api;
//import io.swagger.annotations.ApiOperation;
//
// /**
// * @Description: 部门角色
// * @Author: exez-boot
// * @Date:   2020-02-12
// * @Version: V1.0
// */
//@Slf4j
//@Api(tags="部门角色")
//@RestController
//@RequestMapping("/sys/sysDepartRole")
//public class SysDepartRoleController extends JeecgController<SysDepartRole, ISysDepartRoleService> {
//	@Autowired
//	private ISysDepartRoleService sysDepartRoleService;
//
//	@Autowired
//	private ISysDepartRoleUserService departRoleUserService;
//
//	@Autowired
//	private ISysDepartPermissionService sysDepartPermissionService;
//
//	 @Autowired
//	 private ISysDepartRolePermissionService sysDepartRolePermissionService;
//
//	 @Autowired
//	 private ISysDepartService sysDepartService;
//
//	/**
//	 * 分页列表查询
//	 *
//	 * @param sysDepartRole
//	 * @param pageNo
//	 * @param pageSize
//	 * @param req
//	 * @return
//	 */
//	@ApiOperation(value="部门角色-分页列表查询", notes="部门角色-分页列表查询")
//	@GetMapping(value = "/list")
//	public Result<?> queryPageList(SysDepartRole sysDepartRole,
//								   @RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
//								   @RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
//								   @RequestParam(name="deptId",required=false) String deptId,
//								   HttpServletRequest req) {
//		QueryWrapper<SysDepartRole> queryWrapper = QueryGenerator.initQueryWrapper(sysDepartRole, req.getParameterMap());
//		Page<SysDepartRole> page = new Page<SysDepartRole>(pageNo, pageSize);
//		LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal();
//		List<String> deptIds = null;
////		if(oConvertUtils.isEmpty(deptId)){
////			if(oConvertUtils.isNotEmpty(user.getUserIdentity()) && user.getUserIdentity().equals(CommonConstant.USER_IDENTITY_2) ){
////				deptIds = sysDepartService.getMySubDepIdsByDepId(user.getDepartIds());
////			}else{
////				return Result.ok(null);
////			}
////		}else{
////			deptIds = sysDepartService.getSubDepIdsByDepId(deptId);
////		}
////		queryWrapper.in("depart_id",deptIds);
//
//		//我的部门，选中部门只能看当前部门下的角色
//		queryWrapper.eq("depart_id",deptId);
//		IPage<SysDepartRole> pageList = sysDepartRoleService.page(page, queryWrapper);
//		return Result.ok(pageList);
//	}
//
//	/**
//	 * 添加
//	 *
//	 * @param sysDepartRole
//	 * @return
//	 */
//	//@RequiresRoles({"admin"})
//	@ApiOperation(value="部门角色-添加", notes="部门角色-添加")
//	@PostMapping(value = "/add")
//	public Result<?> add(@RequestBody SysDepartRole sysDepartRole) {
//		sysDepartRoleService.save(sysDepartRole);
//		return Result.ok("添加成功！");
//	}
//
//	/**
//	 * 编辑
//	 *
//	 * @param sysDepartRole
//	 * @return
//	 */
//	//@RequiresRoles({"admin"})
//	@ApiOperation(value="部门角色-编辑", notes="部门角色-编辑")
//	@PutMapping(value = "/edit")
//	public Result<?> edit(@RequestBody SysDepartRole sysDepartRole) {
//		sysDepartRoleService.updateById(sysDepartRole);
//		return Result.ok("编辑成功!");
//	}
//
//	/**
//	 * 通过id删除
//	 *
//	 * @param id
//	 * @return
//	 */
//	//@RequiresRoles({"admin"})
//	@AutoLog(value = "部门角色-通过id删除")
//	@ApiOperation(value="部门角色-通过id删除", notes="部门角色-通过id删除")
//	@DeleteMapping(value = "/delete")
//	public Result<?> delete(@RequestParam(name="id",required=true) String id) {
//		sysDepartRoleService.removeById(id);
//		return Result.ok("删除成功!");
//	}
//
//	/**
//	 * 批量删除
//	 *
//	 * @param ids
//	 * @return
//	 */
//	//@RequiresRoles({"admin"})
//	@AutoLog(value = "部门角色-批量删除")
//	@ApiOperation(value="部门角色-批量删除", notes="部门角色-批量删除")
//	@DeleteMapping(value = "/deleteBatch")
//	public Result<?> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
//		this.sysDepartRoleService.removeByIds(Arrays.asList(ids.split(",")));
//		return Result.ok("批量删除成功！");
//	}
//
//	/**
//	 * 通过id查询
//	 *
//	 * @param id
//	 * @return
//	 */
//	@ApiOperation(value="部门角色-通过id查询", notes="部门角色-通过id查询")
//	@GetMapping(value = "/queryById")
//	public Result<?> queryById(@RequestParam(name="id",required=true) String id) {
//		SysDepartRole sysDepartRole = sysDepartRoleService.getById(id);
//		return Result.ok(sysDepartRole);
//	}
//
//	 /**
//	  * 获取部门下角色
//	  * @param departId
//	  * @return
//	  */
//	@RequestMapping(value = "/getDeptRoleList", method = RequestMethod.GET)
//	public Result<List<SysDepartRole>> getDeptRoleList(@RequestParam(value = "departId") String departId,@RequestParam(value = "userId") String userId){
//		Result<List<SysDepartRole>> result = new Result<>();
//		//查询管理部门下，用户所在部门的所有角色
//		SysDepart depart = sysDepartService.getById(departId);
//		List<SysDepartRole> deptRoleList = sysDepartRoleService.queryDeptRoleByDeptAndUser(depart.getOrgCode(),userId);
//		result.setSuccess(true);
//		result.setResult(deptRoleList);
//		return result;
//	}
//
//	 /**
//	  * 设置
//	  * @param json
//	  * @return
//	  */
//	 @RequestMapping(value = "/deptRoleUserAdd", method = RequestMethod.POST)
//	 public Result<?> deptRoleAdd(@RequestBody JSONObject json) {
//		 String newRoleId = json.getString("newRoleId");
//		 String oldRoleId = json.getString("oldRoleId");
//		 String userId = json.getString("userId");
//		 departRoleUserService.deptRoleUserAdd(userId,newRoleId,oldRoleId);
//		 return Result.ok("添加成功！");
//	 }
//
//	 /**
//	  * 根据用户id获取已设置部门角色
//	  * @param userId
//	  * @return
//	  */
//	 @RequestMapping(value = "/getDeptRoleByUserId", method = RequestMethod.GET)
//	 public Result<List<SysDepartRoleUser>> getDeptRoleByUserId(@RequestParam(value = "userId") String userId){
//		 Result<List<SysDepartRoleUser>> result = new Result<>();
//		 List<SysDepartRoleUser> roleUserList = departRoleUserService.list(new QueryWrapper<SysDepartRoleUser>().eq("user_id",userId));
//		 result.setSuccess(true);
//		 result.setResult(roleUserList);
//		 return result;
//	 }
//
//	 /**
//	  * 查询数据规则数据
//	  */
//	 @GetMapping(value = "/datarule/{permissionId}/{departId}/{roleId}")
//	 public Result<?> loadDatarule(@PathVariable("permissionId") String permissionId,@PathVariable("departId") String departId,@PathVariable("roleId") String roleId) {
//		//查询已授权的部门规则
//	 	List<SysPermissionDataRule> list = sysDepartPermissionService.getPermRuleListByDeptIdAndPermId(departId,permissionId);
//		 if(list==null || list.size()==0) {
//			 return Result.error("未找到权限配置信息");
//		 }else {
//			 Map<String,Object> map = new HashMap<>();
//			 map.put("datarule", list);
//			 LambdaQueryWrapper<SysDepartRolePermission> query = new LambdaQueryWrapper<SysDepartRolePermission>()
//					 .eq(SysDepartRolePermission::getPermissionId, permissionId)
//					 .eq(SysDepartRolePermission::getRoleId,roleId);
//			 SysDepartRolePermission sysRolePermission = sysDepartRolePermissionService.getOne(query);
//			 if(sysRolePermission==null) {
//				 //return Result.error("未找到角色菜单配置信息");
//			 }else {
//				 String drChecked = sysRolePermission.getDataRuleIds();
//				 if(oConvertUtils.isNotEmpty(drChecked)) {
//					 map.put("drChecked", drChecked.endsWith(",")?drChecked.substring(0, drChecked.length()-1):drChecked);
//				 }
//			 }
//			 return Result.ok(map);
//			 //TODO 以后按钮权限的查询也走这个请求 无非在map中多加两个key
//		 }
//	 }
//
//	 /**
//	  * 保存数据规则至角色菜单关联表
//	  */
//	 @PostMapping(value = "/datarule")
//	 public Result<?> saveDatarule(@RequestBody JSONObject jsonObject) {
//		 try {
//			 String permissionId = jsonObject.getString("permissionId");
//			 String roleId = jsonObject.getString("roleId");
//			 String dataRuleIds = jsonObject.getString("dataRuleIds");
//			 log.info("保存数据规则>>"+"菜单ID:"+permissionId+"角色ID:"+ roleId+"数据权限ID:"+dataRuleIds);
//			 LambdaQueryWrapper<SysDepartRolePermission> query = new LambdaQueryWrapper<SysDepartRolePermission>()
//					 .eq(SysDepartRolePermission::getPermissionId, permissionId)
//					 .eq(SysDepartRolePermission::getRoleId,roleId);
//			 SysDepartRolePermission sysRolePermission = sysDepartRolePermissionService.getOne(query);
//			 if(sysRolePermission==null) {
//				 return Result.error("请先保存角色菜单权限!");
//			 }else {
//				 sysRolePermission.setDataRuleIds(dataRuleIds);
//				 this.sysDepartRolePermissionService.updateById(sysRolePermission);
//			 }
//		 } catch (Exception e) {
//			 log.error("SysRoleController.saveDatarule()发生异常：" + e.getMessage(),e);
//			 return Result.error("保存失败");
//		 }
//		 return Result.ok("保存成功!");
//	 }
//
//  /**
//   * 导出excel
//   *
//   * @param request
//   * @param sysDepartRole
//   */
//  @RequestMapping(value = "/exportXls")
//  public ModelAndView exportXls(HttpServletRequest request, SysDepartRole sysDepartRole) {
//      return super.exportXls(request, sysDepartRole, SysDepartRole.class, "部门角色");
//  }
//
//  /**
//   * 通过excel导入数据
//   *
//   * @param request
//   * @param response
//   * @return
//   */
//  @RequestMapping(value = "/importExcel", method = RequestMethod.POST)
//  public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {
//      return super.importExcel(request, response, SysDepartRole.class);
//  }
//
//}
